// Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
// 
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
// 
//     http://www.apache.org/licenses/LICENSE-2.0
// 
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

import React from 'react';
import './RoomCard.css';
import { Room } from '../models/room';
import { useDispatch } from 'react-redux';
import { navigate } from '../middleware/route';

interface RoomCardProps {
  room: Room;
}

const RoomCard: React.FC<RoomCardProps> = ({ room }) => {
  const { name, creator, status, id } = room;
  const dispatch = useDispatch();

  const handleClick = () => {
    dispatch(navigate(`/chat/${id}`));
  };

  return (
    <div className="room-card" onClick={handleClick}>
      <h3 className="room-name">{name}</h3>
      <p className="room-creator">Created by: {creator}</p>
      <div className={`room-status status-${status.toLowerCase().replace(' ', '-')}`}>
        {status}
      </div>
    </div>
  );
};

export default RoomCard;